<template>
  <div class="channel-edit__container">
    <!-- 弹出层的头部区域 -->
    <van-nav-bar title="频道管理">
      <template #right>
        <van-icon name="cross" size="0.37333334rem"
         color="white"
         @click="closepopupFn"/>
         <!-- ×号 -->
      </template>
    </van-nav-bar>
    <!-- 我的频道 -->
    <div class="my-channel-box">
      <div class="channel-title">
        <span>我的频道
          <span class="small-title">
            点击{{ isEdit ? '删除' : '进入' }}频道
          </span>
        </span>
        <span  @click="isEdit = !isEdit"   > {{ isEdit ? '完成' : '编辑' }}    </span>
      </div>
      <!-- 我的频道列表 -->
      <van-row type="flex">
        <van-col span="6"
        v-for="(obj,index) in selecdChannelList"
        :key="obj.id"
         @click="$emit('zhanshi',obj.id)"
        >
          <div class="channel-item van-hairline--surround">
            {{obj.name}}
            <!-- 删除的徽标 -->
            <van-badge color="transparent" class="cross-badge"
              v-if="isEdit && obj.id!==0">
              <template #content>
                <van-icon
                  name="cross"
                  class="badge-icon"
                  color="#cfcfcf"
                  size="0.32rem"
                  @click="delChanneFn(index)"
                />
              </template>
            </van-badge>
          </div>
        </van-col>
      </van-row>
    </div>

    <!-- 更多频道 -->
    <div class="more-channel-box">
      <div class="channel-title">
        <span>点击添加更多频道：</span>
      </div>
      <!-- 更多频道列表 -->
      <van-row type="flex">
        <van-col span="6"
         v-for="obj in unseectedChanneList"
        :key="obj.id"
         @click="addFn(obj)"
        >
        <!-- 名字 -->
          <div class="channel-item van-hairline--surround">
              {{obj.name}}</div>
        </van-col>
      </van-row>
    </div>
  </div>
</template>

<script>
import { getAllChannelListAPI } from '@/api/home'
export default {
  name: 'ChannelEdit',
  props: {
    //   付给子的频道数据  用户选择的频道列表
    selecdChannelList: {
      type: Array,
      required: true
    }
  },

  data () {
    return {
      allChannelList: [], // 所有频
      isEdit: false
    }
  },
  async  created () {
    const res = await getAllChannelListAPI()
    this.allChannelList = res.data.channels
  },
  computed: {
    //   剩余频道 计算
    unseectedChanneList () {
      return this.allChannelList.filter(obj => {
        if (this.selecdChannelList.some(item => item.id === obj.id)) {
          return false
        } else {
          return true
        }
      })
    //    第二简写
      // return !this.selecdChannelList.some(item => item.id === obj.id
    }

  },
  methods: {

    closepopupFn () {
      this.$emit('close-popup')
      setTimeout(() => {
        this.isEdit = false
      }, 500)
    },

    // 添加
    addFn (obj) {
      if (this.isEdit) {
        this.$emit('addChannel', obj)
      } else {
        this.$toast.fail('点击编辑')
      }
    },
    // 删除
    delChanneFn (index) {
      this.$emit('del', index)
    }

  }
}
</script>

<style scoped lang="less">
.van-popup,
.popup-container {
  background-color: transparent;
  height: 100%;
  width: 100%;
}

.popup-container {
  display: flex;
  flex-direction: column;
}

.pop-header {
  height: 90px;
  background-color: #007bff;
  color: white;
  text-align: center;
  font-size: 14px;
  position: relative;
  .title {
    width: 100%;
    position: absolute;
    bottom: 15px;
  }
}

.pop-body {
  flex: 1;
  overflow: scroll;
  padding: 8px;
  background-color: white;
}

.my-channel-box,
.more-channel-box {
  .channel-title {
    display: flex;
    justify-content: space-between;
    font-size: 14px;
    line-height: 28px;
    padding: 0 6px;
  }
}

.channel-item {
  font-size: 12px;
  text-align: center;
  line-height: 36px;
  background-color: #fafafa;
  margin: 5px;
}

/*删除的微标 */
.cross-badge {
  position: absolute;
  right: -3px;
  top: 0;
  border: none;
}

/*提示文字 */
.small-title {
  font-size: 10px;
  color: gray;
}
</style>
